Other Classes

The following classes are available globally.

  • The NavigationEventsManager is responsible for being the liaison between MapboxCoreNavigation and the Mapbox telemetry framework.

    See more

    Declaration

    Swift

    @objc(MBNavigationEventsManager)
    open class NavigationEventsManager : NSObject
  • NavigationLocationManager is the base location manager which handles permissions and background modes.

    Declaration

    Swift

    @objc(MBNavigationLocationManager)
    open class NavigationLocationManager : CLLocationManager
  • A NavigationRouteOptions object specifies turn-by-turn-optimized criteria for results returned by the Mapbox Directions API.

    NavigationRouteOptions is a subclass of RouteOptions that has been optimized for navigation. Pass an instance of this class into the Directions.calculate(_:completionHandler:) method.

    Note

    NavigationRouteOptions is designed to be used with the Directions and NavigationDirections classes for specifying routing criteria. To customize the user experience in a NavigationViewController, use the NavigationOptions class.
    See more

    Declaration

    Swift

    @objc(MBNavigationRouteOptions)
    open class NavigationRouteOptions : RouteOptions
  • A NavigationMatchOptions object specifies turn-by-turn-optimized criteria for results returned by the Mapbox Map Matching API.

    NavigationMatchOptions is a subclass of MatchOptions that has been optimized for navigation. Pass an instance of this class into the Directions.calculateRoutes(matching:completionHandler:). method.

    Note: it is very important you specify the waypoints for the route. Usually the only two values for this IndexSet will be 0 and the length of the coordinates. Otherwise, all coordinates passed through will be considered waypoints.

    See more

    Declaration

    Swift

    @objc(MBNavigationMatchOptions)
    open class NavigationMatchOptions : MatchOptions
  • NavigationSettings provides a wrapper for UserDefaults.

    Properties are prefixed and before they are stored in UserDefaults.standard.

    See more

    Declaration

    Swift

    @objc(MBNavigationSettings)
    public class NavigationSettings : NSObject
  • A NavigationDirections object provides you with optimal directions between different locations, or waypoints. The directions object passes your request to a built-in routing engine and returns the requested information to a closure (block) that you provide. A directions object can handle multiple simultaneous requests. A RouteOptions object specifies criteria for the results, such as intermediate waypoints, a mode of transportation, or the level of detail to be returned. In addition to Directions, NavigationDirections provides support for offline routing.

    Each result produced by the directions object is stored in a Route object. Depending on the RouteOptions object you provide, each route may include detailed information suitable for turn-by-turn directions, or it may include only high-level information such as the distance, estimated travel time, and name of each leg of the trip. The waypoints that form the request may be conflated with nearby locations, as appropriate; the resulting waypoints are provided to the closure.

    See more

    Declaration

    Swift

    @objc(MBNavigationDirections)
    public class NavigationDirections : Directions
  • A user interface element designed to display the estimated arrival time, distance, and time remaining, as well as give the user a control the cancel the navigation session.

    See more

    Declaration

    Swift

    @IBDesignable
    @objc(MBBottomBannerViewController)
    open class BottomBannerViewController : UIViewController, NavigationComponent
  • CarPlayMapViewController is responsible for administering the Mapbox map, the interface styles and the map template buttons to display on CarPlay.

    See more

    Declaration

    Swift

    @objc(MBCarPlayMapViewController)
    public class CarPlayMapViewController : UIViewController
  • CarPlaySearchController is the main object responsible for managing the search feature on CarPlay.

    Messages declared in the CPApplicationDelegate protocol should be sent to this object in the containing application’s application delegate. Implement CarPlaySearchControllerDelegate in the containing application and assign an instance to the delegate property of your CarPlaySearchController instance.

    Note

    It is very important you have a single CarPlaySearchController instance at any given time.
    See more

    Declaration

    Swift

    @objc(MBCarPlaySearchController)
    public class CarPlaySearchController : NSObject
  • CarPlay support requires iOS 12.0 or above and the CarPlay framework.

  • A view controller containing a grid of buttons the user can use to denote an issue their current navigation experience.

    See more

    Declaration

    Swift

    @objc(MBFeedbackViewController)
    public class FeedbackViewController : UIViewController, DismissDraggable, UIGestureRecognizerDelegate
  • Customization options for the turn-by-turn navigation user experience in a NavigationViewController.

    A navigation options object is where you place customized components that the navigation view controller uses during its lifetime, such as styles or voice controllers. You would likely use this class if you need to specify a Mapbox access token programmatically instead of in the Info.plist file.

    Note

    NavigationOptions is designed to be used with the NavigationViewController class to customize the user experience. To specify criteria when calculating routes, use the NavigationRouteOptions class.
    See more

    Declaration

    Swift

    @objc(MBNavigationOptions)
    open class NavigationOptions : NSObject, NavigationCustomizable
  • A view that represents the root view of the MapboxNavigation drop-in UI.

    Components

    1. InstructionsBannerView
    2. InformationStackView
    3. BottomBannerView
    4. ResumeButton
    5. WayNameLabel
    6. FloatingStackView
    7. NavigationMapView
    +--------------------+
    |         1          |
    +--------------------+
    |         2          |
    +----------------+---+
    |                |   |
    |                | 6 |
    |                |   |
    |         7      +---+
    |                    |
    |                    |
    |                    |
    +------------+       |
    |  4  ||  5  |       |
    +------------+-------+
    |         3          |
    +--------------------+
    

    Declaration

    Swift

    @IBDesignable
    @objc(MBNavigationView)
    open class NavigationView : UIView
  • A manager that handles Style objects. The manager listens for significant time changes and changes to the content size to apply an approriate style for the given condition.

    See more

    Declaration

    Swift

    @objc(MBStyleManager)
    open class StyleManager : NSObject